/**
 * 给定一个赎金信 (ransom) 字符串和一个杂志(magazine)字符串，判断第一个字符串ransom能不能由第二个字符串magazines里面的字符构成。如果可以构成，返回 true ；否则返回 false。
 * (题目说明：为了不暴露赎金信字迹，要从杂志上搜索各个需要的字母，组成单词来表达意思。)
 * 你可以假设两个字符串均只含有小写字母。
 * @param {string} ransomNote
 * @param {string} magazine
 * @return {boolean}
 */
var canConstruct = function(ransomNote, magazine) {
  // 只需要 magazines字符个数都大于 ransom里字符个数即可。
  if (magazine.length < ransomNote.length) {
    return false
  }
  let magazineMap = {}
  for (let i of magazine) {
    if (magazineMap[i]) {
      magazineMap[i]++
    } else {
      magazineMap[i] = 1
    }
  }
  console.log('magazineMap', magazineMap)
  for (let i of ransomNote) {
    if (!magazineMap[i] || magazineMap[i] <= 0) {
      return false
    } else {
      magazineMap[i]--
    }
  }
  return true
};
(function () {
  let ransomNote = 'aa'
  let magazine = 'ab'
  console.log(canConstruct(ransomNote, magazine))
}())